#include<cstdio>
#include<cstring>
#include<algorithm>
#define INF 0x3f3f3f3f
using namespace std;
typedef long long LL;
typedef double db;
inline int read()
{
	int x=0,f=1;
	char ch=getchar();
	while(ch<'0'||ch>'9') { if(ch=='-')f=-1; ch=getchar(); }
	while(ch>='0'&&ch<='9') { x=(x<<1)+(x<<3)+ch-'0'; ch=getchar(); }
	return x*f;
}
const int MAXN=2010;
int n,h,d,a[MAXN][MAXN],f[MAXN][MAXN],_max[MAXN];
int main()
{
	n=read();h=read();d=read();
	for(int i=1;i<=n;++i)
	{
		int m=read();
		for(int j=1;j<=m;++j)
		{
			int x=read();
			++a[i][x];
		}
	}
	for(int i=1;i<=n;++i)f[i][h]=a[i][h],_max[h]=max(_max[h],a[i][h]);
	for(int j=h-1;j;--j)
		for(int i=1;i<=n;++i)
		{
			if(j+d<=h)f[i][j]=_max[j+d];
			f[i][j]=max(f[i][j],f[i][j+1]);
			_max[j]=max(_max[j],f[i][j]+=a[i][j]);
		}
	printf("%d\n",_max[1]);
	return 0;
}
